# METHOD TO SOLVE SIMILAR TIMING PATHS Von-Kyoung Kim, et al. Atty. Docket No.: 004-8844 1/6

100 \_\_\_\_



FIG. 1

## METHOD TO SOLVE SIMILAR TIMING PATHS Von-Kyoung Kim, et al. Atty. Docket No.: 004-8844 2/6

200 PARSE STATIC TIMING REPORT ACCORDING TO BUCKET CONTROL FILE 206 **IDENTIFY TIMING PATHS FOR OPTIMIZATION** <u>208</u> **GROUP PATHS INTO BUCKETS** 210 **GROUP PATHS INTO SIGNATURES** <u>212</u> GENERATE TIMING REPORT AND PATH STATISTICS ACCORDING TO BUCKETS AND SIGNATURES <u>214</u> IMPROVE A REPRESENTATIVE CIRCUIT CORRESPONDING TO A SIGNATURE <u>216</u> SUBSTITUTE CIRCUITS WITH INSTANCES OF **IMPROVED CIRCUITS** <u>218</u>

FIG. 2

Von-Kyoung Kim, et al. Atty. Docket No.: 004-8844

3/6

302 (1) Bucket by source block name: BUCKET: emcu\_ecu\_ecaddr\_ctl PRIORITY: 43 SOURCE: emcu\_ecu\_ecaddr\_ctl ←bucket by source block **DESTINATION:** NET: **DEVICE:** 304 (2) Bucket by destination block name: BUCKET: emcu\_ecu\_ecaddr\_dp PRIORITY: 45 SOURCE: DESTINATION: emcu\_ecu\_ecaddr\_dp ←bucket by destination block DEVICE: 306 (3) Bucket by source block name: BUCKET: ramtest PRIORITY: 100 SOURCE: DESTINATION: NET: ramtest ← bucket by common net name (useful for bus) **DEVICE:** 308 (4) Bucket by device name: BUCKET: emu\_ecu\_ecaddr\_dp PRIORITY: 45 SOURCE: **DESTINATION:** DEVICE: paths\_share\_common\_device ← bucket by common device 310 (5) Bucket by combination of fields: BUCKET: ramtest PRIORITY: 100 SOURCE: ramtest **DESTINATION:** ramtest NET: ramtest

**DEVICE:** ramtest

Von-Kyoung Kim, et al. Atty. Docket No.: 004-8844

4/6



FIG. 4C

Von-Kyoung Kim, et al. Atty. Docket No.: 004-8844

5/6

MAX T = 0.974 ns: 30 paths: 3 signatures: BUCKET 1 AAA MAX T = 0.957 ns: 6 paths: 1 signatures: BUCKET 2\_BBB

<1\_\_emu>

#1: BUCKET: AAA

PRIORITY: 45 SOURCE: **DESTINATION:** NET: aaa **DEVICE:** 

Number of paths = 30

Number of signatures = 2

signature # 1 : ecram.mux4i.inv.eccgen.fsdsql

bucket: 1\_AAA

p1(0.974ns) p2 (0.971ns) p6(0.967ns) p7(0.967ns)

Possibility 1:

Setup constraint violation 0.024ns dev\_6 (fsdsql\_24x d v -> 12 clk  $^{\circ}$ ) Clk edge: clk  $^{\circ}$  -> dev\_6/12clk  $^{\circ}$  at 0.000ns +Tcycle = 0.950ns

Clock jitter: 0.100ns Setup time: -0.120ns

Data dege: clk  $^-$  -> dev\_6/d[1] v at 0.994ns Required cycle time: 0.974ns (1.00 cycle path)

|   | Delay   | Gate    | Wire    | Load Cap  | Node  | Device | Cell     | Pin to Pin                                 |
|---|---------|---------|---------|-----------|-------|--------|----------|--------------------------------------------|
|   | 0.000ns | 0.000ns | 0.000ns | 560.236pF | clk ^ |        |          |                                            |
| * | 0.000ns | 0.582ns | 0.000ns | 0.027pF   | clk ^ | dev_1  | ecram    | $clk ^ \rightarrow do ^$                   |
|   | 0.582ns | 0.000ns | 0.001ns | 0.027pF   | aaa ^ |        |          |                                            |
|   | 0.584ns | 0.048ns | 0.000ns | 0.021pF   | aaa ^ | dev_2  | rptr_48x | in $^{\wedge} \rightarrow$ out $^{\wedge}$ |
|   | 0.632ns | 0.000ns | 0.040ns | 0.021pF   | bbb ^ |        |          |                                            |
| * | 0.672ns | 0.061ns | 0.000ns | 0.036pF   | bbb ^ | dev_3  | mux4i_8x | d2 $^{\rightarrow}$ out v                  |
|   | 0.732ns | 0.000ns | 0.001ns | 0.036pF   | ccc v |        |          |                                            |
|   | 0.733ns | 0.036ns | 0.000ns | 0.151pF   | ccc v | dev_4  | inv_24x  | in v $\rightarrow$ out $^{\wedge}$         |
|   | 0.770ns | 0.000ns | 0.022ns | 0.151pF   | ddd ^ |        |          |                                            |
|   | 0.792ns | 0.202ns | 0.000ns | 0.003pF   | ddd ^ | dev_5  | eccgen   | chk $^{\wedge} \rightarrow ec v$           |
|   | 0.993ns | 0.000ns | 0.000ns | 0.003pF   | eee v |        |          |                                            |
|   | 0.994ns |         |         |           | eee v |        |          |                                            |
|   |         |         |         |           |       |        |          |                                            |

Von-Kyoung Kim, et al. Atty. Docket No.: 004-8844

6/6

signature # 2 : ecram.mux4i.inv.eccgen

bucket: 1\_AAA

 $\begin{array}{l} p3(0.969ps)\ p4(0.967ns)\ p5(0.967ns)\ p8(0.966ns)\ p9(0.965ns)\ p10(0.965ns)\\ p11(0.959ns)\ p12(0.958ns)\ p13(0.958ns)\ p16(0.957ns)\ p17(0.956ns)\ p20(0.956ns)\\ p21(0.956ns)\ p22(0.956ns)\ p23(0.955ns)\ p26(0.954ns)\ p27(0.954ns)\ p28(0.953ns)\\ p29(0.952ns)\ p30(0.952ns)\ p31(0.952ns)\ p32(0.952ns)\ p33(0.952ns)\ p34(0.952ns)\\ p35(0.950ns)\ p36(0.950ns) \end{array}$ 

Possibility 3:

Setup constraint violation 0.019ns dev\_5 (eccgen check[3] ^ -> clk ^) Clk edge: clk ^ -> dev\_5/clk ^ at 0.000ns + Tcycle = 0.950ns

> Clock jitter: 0.100ns Setup time: 0.078ns

Data edge: clk ^ -> dev\_5/check[3] ^ at 0.792ns Required cycle time: 0.969ns (1.00 cycle path)

|   | Delay   | Gate    | Wire    | Load Cap  | Node  | Device | Cell     | Pin to Pin                                 |
|---|---------|---------|---------|-----------|-------|--------|----------|--------------------------------------------|
|   | 0.000ns | 0.000ns | 0.000ns | 560.236pF | clk ^ |        |          |                                            |
| * | 0.000ns | 0.582ns | 0.000ns | 0.027pF   | clk ^ | dev_1  | ecram    | clk $^{\wedge} \rightarrow$ do $^{\wedge}$ |
|   | 0.582ns | 0.000ns | 0.001ns | 0.027pF   | aaa ^ |        |          |                                            |
|   | 0.584ns | 0.048ns | 0.000ns | 0.021pF   | aaa ^ | dev_2  | rptr_48x | in $^{\wedge} \rightarrow$ out $^{\wedge}$ |
|   | 0.632ns | 0.000ns | 0.040ns | 0.021pF   | bbb ^ |        |          |                                            |
| * | 0.672ns | 0.061ns | 0.000ns | 0.036pF   | bbb ^ | dev_3  | mux4i_8x | d2 $^{\rightarrow}$ out v                  |
|   | 0.732ns | 0.000ns | 0.001ns | 0.036pF   | ccc v |        |          | •                                          |
|   | 0.733ns | 0.036ns | 0.000ns | 0.151pF   | ccc v | dev_4  | inv_24x  | in $v \rightarrow out$                     |
|   | 0.770ns | 0.000ns | 0.022ns | 0.151pF   | ddd ^ |        |          |                                            |
|   | 0.792ns |         |         | •         | ddd ^ |        | ,        |                                            |
|   |         |         |         |           |       |        |          |                                            |

### FIG. 5B

| MAX T = | 0.847ns:  | 29 paths :  | 5 signatures : | BUCKET 1_AAÂ |
|---------|-----------|-------------|----------------|--------------|
| MAX T = | 0.842ns:  | 2 paths :   | 1 signatures : | BUCKET 2_BBB |
| MAX T = | 0.841ns:  | 138 paths : | 3 signatures : | BUCKET 3_CCC |
| MAXT =  | 0.840ns:  | 134 paths : | 5 signatures : | BUCKET 4_DDD |
| MAX T = | 0.839ns:  | 18 paths :  | 7 signatures : | BUCKET 5_EEE |
| MAX T = | 0.830ns : | 3 paths :   | 2 signatures : | BUCKET 6_FFF |
| MAXT =  | 0.824ns : | 2 paths :   | 1 signatures : | BUCKET 7_GGG |